page{
    height: 100%;
    overflow: hidden;
}

.viewport{
    height: 100%;
    display: flex;
    flex-direction: column;
}

.search{
    background-color: #fff;
    padding: 20rpx 30rpx;

    .input {
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: 64rpx;
        padding-left: 26rpx;
        color: #8b8b8b;
        font-size: 28rpx;
        border-radius: 32rpx;
        background-color: #f3f4f4;
      }

    .icon-search {
        &::before {
          margin-right: 10rpx;
        }
    }
}

/* 分类 */
.categories {
    flex: 1;
    min-height: 400rpx;
    display: flex;
}

.primary{
    overflow: hidden;
    width: 180rpx;
    flex: none;
    background-color: #f6f6f6;

    .item{
        display: flex;
        justify-content: center;
        align-items: center;
        height: 96rpx;
        font-size: 26rpx;
        color: #595c63;
        position: relative;

        &::after {
            content: '';
            position: absolute;
            left: 42rpx;
            bottom: 0;
            width: 96rpx;
            border-top: 1rpx solid #e3e4e7;
          }
    }
    .active{
        background-color: #fff;
        &::before{
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            width: 8rpx;
            height: 100%;
            background-color: #27ba9b;
        }
    }
}

.primary .item:last-child::after,
.primary .active::after {
  display: none;
}

/* 二级分类 */
.secondary {
    background-color: #fff;
    .carousel {
      height: 200rpx;
      margin: 0 30rpx 20rpx;
      border-radius: 4rpx;
      overflow: hidden;
    }
    .panel {
      margin: 0 30rpx 0rpx;
    }
    .title {
      height: 60rpx;
      line-height: 60rpx;
      color: #333;
      font-size: 28rpx;
      border-bottom: 1rpx solid #f7f7f8;
      .more {
        float: right;
        padding-left: 20rpx;
        font-size: 24rpx;
        color: #999;
      }
    }
    .more {
      &::after {
        font-family: 'erabbit' !important;
        content: '\e6c2';
      }
    }
    .section {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      padding: 20rpx 0;
      .goods {
        width: 150rpx;
        margin: 0rpx 20rpx 20rpx 0;
        &:nth-child(3n) {
          margin-right: 0;
        }
        .image {
          width: 150rpx;
          height: 150rpx;
        }
        .name {
          padding: 5rpx;
          font-size: 22rpx;
          color: #333;
          -webkit-line-clamp: 2;
          text-overflow: ellipsis;
        }
        .price {
          padding: 5rpx;
          font-size: 18rpx;
          color: #cf4444;
        }
        .number {
          font-size: 24rpx;
          margin-left: 2rpx;
        }
      }
    }
  }
  